Pontifícia Universidade Católica de Minas Gerais Instituto de Ciências Exatas e Informática – ICEI Arquitetura de Computadores I

ARQ1 \_ Aula\_06

Tema: Introdução à linguagem Verilog e simulação em Logisim

Preparação

Vídeos recomendados

https://www.youtube.com/watch?v=SvcTSNCB4zIhttps://www.youtube.com/watch?v=VkJ71Js3QDwhttps://www.youtube.com/watch?v=JUVeGaJkuDY

## Orientação geral:

Apresentar uma forma de solução em formato texto (.txt).

Os arquivos para simulação em Logisim (.circ) deverão ser identificados internamente e entregues, acompanhados (ou não) de figuras equivalentes exportadas pela ferramenta.

Separar as versões completas (a) das simplificadas (b).

Programas em Verilog poderão ser entregues em formato (.v) com previsão de testes.

Atividade: Simplificação de circuitos

01.) Funções lógicas podem ser simplificadas diretamente do mapa de Veitch-Karnaugh:

|   |      | E   |     |   |
|---|------|-----|-----|---|
|   | xy∖z | 0   | 1   |   |
| Α | 00   | (0) | (1) | D |
|   | 01   | (2) | (3) | С |
|   | 11   | (6) | (7) | - |
| В | 10   | (4) | (5) | D |
|   |      |     |     |   |

$$A = x' \cdot f(z)$$

$$B = x \cdot f(z)$$

$$C = y \cdot f(z)$$

$$D = y' \cdot f(z)$$

$$E = f(x,y)$$

# Exemplo:

Dado o mapa de Veitch-Karnaugh abaixo, determinar a função simplificada equivalente.

|   | xy∖z | 0                       | 1                       |   |
|---|------|-------------------------|-------------------------|---|
| Α | 00   | (0)                     | <b>1</b> <sup>(1)</sup> | D |
|   | 01   | <b>1</b> <sup>(2)</sup> | <b>1</b> <sup>(3)</sup> | С |
|   | 11   | (6)                     | (7)                     | = |
| В | 10   | <b>1</b> <sup>(4)</sup> | (5)                     | D |

$$f(x,y,z) = \sum m(1,2,3,4) = x' \cdot y' \cdot z + x' \cdot y \cdot z' + x' \cdot y \cdot z + x \cdot y' \cdot z'$$

$$f(x,y,z) = \sum m(1,2,3,4) = x' \cdot z + x' \cdot y' + x \cdot y' \cdot z'$$

Montar o mapa de Veitch-Karnaugh e simplificar as funções lógicas abaixo e verificar pelas respectivas tabelas-verdades implementadas em Verilog:

a) 
$$f(x,y,z) = \sum m(1, 4, 5)$$

b) 
$$f(x,y,z) = \sum m(0, 2, 6)$$

c) 
$$f(x,y,z) = \sum m(1, 2, 3, 5)$$

d) 
$$f(x,y,z) = \sum m(1, 2, 5, 7)$$

e) 
$$f(x,y,z) = \sum m (0, 2, 5, 6)$$

03.) O mapa de Veitch-Karnaugh também serve para simplificar produtos de somas (MAXTERMOS):

$$A = X + F(Z)$$

$$\mathsf{B} = \mathsf{X}' + \mathsf{F}(\mathsf{Z})$$

$$C = Y' + F(Z)$$

$$D = Y' + F(Z)$$

$$E = F(X,Y)$$

#### Exemplo:

Dado o mapa de Veitch-Karnaugh abaixo, determinar o produto das somas (PoS) simplificado.

|   | $XY\Z$ | 0                       | 1                       |   |
|---|--------|-------------------------|-------------------------|---|
| Α | 00     | <b>O</b> <sup>(0)</sup> | <b>1</b> <sup>(1)</sup> | D |
|   | 01     | <b>1</b> <sup>(2)</sup> | <b>1</b> <sup>(3)</sup> | С |
|   | 11     | <b>0</b> <sup>(6)</sup> | <b>0</b> <sup>(7)</sup> | _ |
| В | 10     | <b>1</b> <sup>(4)</sup> | <b>0</b> <sup>(5)</sup> | D |

$$F(X,Y,Z) = \Pi M(0,5,6,7) = (X+Y+Z) \cdot (X'+Y+Z') \cdot (X'+Y'+Z) \cdot (X'+Y'+Z')$$

(B)

$$F(X,Y,Z) = \Pi M(0,5,6,7) = (X+Y+Z) \cdot (X'+Z') \cdot (X'+Y')$$

Montar o mapa de Veitch-Karnaugh e simplificar as funções lógicas abaixo por MAXTERMOS e verificar pelas respectivas tabelas-verdades implementadas em Verilog:

a) 
$$F(X,Y,Z) = \mathbf{T} M(0,5,7)$$

b) 
$$F(X,Y,Z) = \Pi M(1,3,7)$$

c) 
$$F(X,Y,Z) = \Pi M(1, 2, 5, 6)$$

d) 
$$F(X,Y,Z) = \Pi M(0, 2, 4, 5)$$

e) 
$$F(X,Y,Z) = \Pi M(2,3,5,6)$$

03.) Se o número de variáveis aumentar, o mapa deve ser modificado ligeiramente, a fim de que as vizinhanças mantenham apenas um diferença entre elas.

|   |       | Е    |      | F    |      |   |
|---|-------|------|------|------|------|---|
|   | xy\wz | 00   | 01   | 11   | 10   |   |
| Α | 00    | (0)  | (1)  | (3)  | (2)  | D |
| • | 01    | (4)  | (5)  | (7)  | (6)  | С |
|   | 11    | (12) | (13) | (15) | (14) |   |
| В | 10    | (8)  | (9)  | (11) | (10) | D |
|   |       | Н    | G    | -    | Н    |   |

### Exemplo:

Dado o mapa de Veitch-Karnaugh abaixo, determinar a função simplificada equivalente.



$$f(x,y,w,z) = \sum m (1, 2, 6, 7, 9, 12, 14)$$

$$= x' \cdot y' \cdot w' \cdot z + x' \cdot y' \cdot w \cdot z' + x' \cdot y \cdot w \cdot z' + x' \cdot y \cdot w \cdot z + x \cdot y' \cdot w' \cdot z + x \cdot y \cdot w' \cdot z' + x \cdot y \cdot w \cdot z' + x' \cdot y \cdot w \cdot z'$$

$$f(x,y,w,z) = x' \cdot w \cdot z' + x' \cdot y \cdot w + y' \cdot w' \cdot z + x \cdot y \cdot z'$$

Construir os mapas de Veitch-Karnaugh e simplificar as funções lógicas abaixo e verificar pelas respectivas tabelas-verdades implementadas em Verilog:

a) 
$$f(x,y,w,z) = \sum m(1, 2, 4, 6, 14, 15)$$

b) 
$$f(x,y,w,z) = \sum m (0, 2, 3, 4, 7, 11)$$

c) 
$$f(x,y,w,z) = \sum m(0, 1, 2, 3, 5, 7, 9, 13)$$

d) 
$$f(x,y,w,z) = \sum m(2, 4, 6, 10, 12, 14)$$

e) 
$$f(x,y,w,z) = \sum m(0, 1, 2, 4, 8, 13, 14, 15)$$

04.) O mapa de Veitch-Karnaugh também serve para simplificar produtos de somas (MAXTERMOS):

|   | E       |      |      | F    |      |     |
|---|---------|------|------|------|------|-----|
|   | $XY\WZ$ | 00   | 01   | 11   | 10   |     |
| Α | 00      | (0)  | (1)  | (3)  | (2)  | _ D |
| • | 01      | (4)  | (5)  | (7)  | (6)  | С   |
|   | 11      | (12) | (13) | (15) | (14) | _   |
| В | 10      | (8)  | (9)  | (11) | (10) | D   |
|   |         | Н    | G    |      | Н    | _   |

$$A = X + F(W,Z)$$
  $E = G(X,Y) + W$   $(A,B) = F(W,Z)$   
 $B = X' + F(W,Z)$   $F = G(X,Y) + W'$   $(C,D) = F(W,Z)$   
 $C = Y' + F(W,Z)$   $G = G(X,Y) + Z'$   $(E,F) = G(X,Y)$   
 $D = Y + F(W,Z)$   $H = G(X,Y) + Z$   $(G,H) = G(X,Y)$ 

# Exemplo:

Dado o mapa de Veitch-Karnaugh abaixo, determinar o produto de somas (PoS) simplificado.

|   | E       |                          |                          | F                        |                          |   |
|---|---------|--------------------------|--------------------------|--------------------------|--------------------------|---|
|   | $XY\WZ$ | 00                       | 01                       | 11                       | 10                       |   |
| Α | 00      | <b>1</b> <sup>(0)</sup>  | <b>1</b> <sup>(1)</sup>  | <b>1</b> <sup>(3)</sup>  | <b>1</b> <sup>(2)</sup>  | D |
| • | 01      | 1 <sup>(4)</sup>         | <b>0</b> <sup>(5)</sup>  | <b>0</b> <sup>(7)</sup>  | <b>1</b> <sup>(6)</sup>  | С |
|   | 11      | <b>1</b> <sup>(12)</sup> | <b>0</b> <sup>(13)</sup> | <b>0</b> <sup>(15)</sup> | <b>1</b> <sup>(14)</sup> | _ |
| В | 10      | <b>0</b> <sup>(8)</sup>  | <b>1</b> <sup>(9)</sup>  | <b>1</b> <sup>(11)</sup> | <b>0</b> <sup>(10)</sup> | D |
| • |         | Н                        | G                        |                          | Н                        |   |

$$\mathsf{F}\ (\mathsf{X},\mathsf{Y},\mathsf{W},\mathsf{Z}) = (\mathsf{Y}'+\mathsf{Z}') \bullet (\mathsf{X}'+\mathsf{Y}+\mathsf{Z})$$

Construir os mapas de Veitch-Karnaugh e simplificar as funções lógicas abaixo por MAXTERMOS e verificar pelas respectivas tabelas-verdades implementadas em Verilog:

a) 
$$F(X,Y,W,Z) = \mathbf{T} M(2, 6, 8, 10)$$

b) 
$$F(X,Y,W,Z) = \Pi M(4,7,9,11,13)$$

c) 
$$F(X,Y,W,Z) = \Pi M(4, 8, 12, 14, 15)$$

d) 
$$F(X,Y,W,Z) = \Pi M(1,3,5,7,11,14)$$

e) 
$$F(X,Y,W,Z) = \Pi M(4, 5, 6, 7, 13, 15)$$

09.) Identificar a equação característica do circuito lógicos abaixo e simplificá-la pelo mapa de Veitch-Karnaugh usando mintermos. Descrever e simular o circuito simplificado em Verilog e Logisim.



10.) Identificar as equações características dos circuitos lógicos abaixo e simplificá-las pelo mapa de Veitch-Karnaugh usando MAXTERMOS. Descrever e simular o circuito simplificado em Verilog e Logisim.

